<!--用户注册页面-->
<template>
  <div id="userRegisterPage">
    <h2 class="title">鱼皮皮云图库 - 用户注册</h2>
    <div class="desc">企业级智能协同云图库</div>
    <a-form
      :model="formState"
      name="basic"
      autocomplete="off"
      @finish="handleSubmit"
    >
      <a-form-item
        name="userAccount"
        :rules="[{ required: true, message: '请输入账号' }]"
      >
        <a-input v-model:value="formState.userAccount" placeholder="请输入账号"/>
      </a-form-item>

      <a-form-item
        name="userPassword"
        :rules="[
          { required: true, message: '请输入密码' },
          { min: 8, message: '密码长度不能小于8位' }]"
      >
        <a-input-password v-model:value="formState.userPassword" placeholder="请输入密码"/>
      </a-form-item>
      <a-form-item
        name="checkPassword"
        :rules="[
          { required: true, message: '请输入确认密码' },
          { min: 8, message: '确认密码长度不能小于8位' }]"
      >
        <a-input-password v-model:value="formState.checkPassword" placeholder="请输入确认密码"/>
      </a-form-item>
      <div class="tips">
        已有账号？
        <RouterLink to="/user/login">去登录</RouterLink>
      </div>
      <a-form-item>
        <a-button type="primary" html-type="submit" style="width: 100%">注册</a-button>
      </a-form-item>
    </a-form>
  </div>
</template>
<script lang="ts" setup>
import { reactive } from 'vue';
import {userRegisterUsingPost} from "@/api/userController";
import {message} from "ant-design-vue";
import {useRouter} from "vue-router";
const router = useRouter();

//用于接受表单输入的值
const formState = reactive<API.UserRegisterRequest>({
  userAccount: '',
  userPassword: '',
  checkPassword: ''
});
//表单提交
const handleSubmit = async (values: any) => {
  //校验两次密码是否一致
  if(values.userPassword !== values.checkPassword){
    message.error('两次密码不一致');
    return;
  }
  const res = await userRegisterUsingPost(values)
  //注册成功，跳转到登录页
  if(res.data.code === 0 && res.data.data){
    message.success('注册成功');
    //跳转到登录页
    router.push({
      path:'/user/login',
      replace:true,
    });
  }else {
    message.error('注册失败，' + res.data.message);
  }
};
</script>

<style scoped>
#userRegisterPage {
  max-width: 360px;
  margin: 0 auto;
}
#userRegisterPage .title {
  text-align: center;
  margin-bottom: 16px;
}
#userRegisterPage .desc {
  text-align: center;
  color: #bbb;
  margin-bottom: 16px;
}
#userRegisterPage .tips {
  text-align: right;
  margin-bottom: 16px;
  color: #bbb;
  font-size: 13px;
}
</style>

